Recursion এবং Iteration এর ধারণা

Computer Programming - ক্লোজার (Clojure) Looping এবং Iteration (Looping and Iteration) |
246
246

রিকার্সন (Recursion) এবং ইটারেশন (Iteration) এর ধারণা

রিকার্সন এবং ইটারেশন প্রোগ্রামিংয়ে বারবার পুনরাবৃত্তি করে কাজ সম্পন্ন করার দুটি পদ্ধতি। এই দুই পদ্ধতি কার্যক্ষমতা এবং প্রয়োগের ক্ষেত্রে পার্থক্য রয়েছে। চলুন রিকার্সন এবং ইটারেশনের ধারণা, প্রয়োগ এবং পার্থক্য সম্পর্কে আলোচনা করা যাক।


রিকার্সন (Recursion)

রিকার্সন একটি প্রোগ্রামিং পদ্ধতি যেখানে একটি ফাংশন নিজেই নিজেকে বারবার কল করে কাজ সম্পন্ন করে। রিকার্সনে সাধারণত একটি বেস কেস (যেখানে রিকার্সন থামে) এবং একটি রিকার্সিভ কেস (যেখানে ফাংশন নিজেকে পুনরায় কল করে) থাকে। রিকার্সন সাধারণত জটিল সমস্যাগুলিকে সরল এবং পুনরাবৃত্তভাবে সমাধান করার জন্য ব্যবহৃত হয়।

উদাহরণ: ফ্যাক্টরিয়াল গণনা

ফ্যাক্টরিয়াল গণনার জন্য একটি রিকার্সিভ ফাংশন লেখা যেতে পারে যেভাবে:

(defn factorial [n]
  (if (<= n 1)
    1
    (* n (factorial (dec n)))))

এখানে, factorial ফাংশনটি নিজেই নিজেকে কল করছে যতক্ষণ পর্যন্ত n এর মান ১ বা তার চেয়ে কম না হয়। এই ফাংশনটি n এর মানকে প্রতি রিকার্সিভ কলে কমিয়ে দেয় এবং অবশেষে ফ্যাক্টরিয়াল রিটার্ন করে।


ইটারেশন (Iteration)

ইটারেশন একটি পদ্ধতি যেখানে একটি নির্দিষ্ট শর্ত পর্যন্ত একটি লুপ বারবার চালানো হয়। ইটারেশন সাধারণত for, while, বা loop কন্সট্রাক্ট ব্যবহার করে করা হয়। ইটারেশন লুপের মাধ্যমে কাজ সম্পন্ন করে এবং সাধারণত কম মেমোরি ব্যবহার করে, কারণ এটি স্ট্যাক ফ্রেমের উপর নির্ভর করে না।

উদাহরণ: ফ্যাক্টরিয়াল গণনা

ফ্যাক্টরিয়াল গণনার জন্য একটি ইটারেটিভ পদ্ধতি লেখা যেতে পারে এভাবে:

(defn factorial [n]
  (loop [i n, acc 1]
    (if (<= i 1)
      acc
      (recur (dec i) (* acc i)))))

এখানে loop এবং recur ব্যবহার করে একটি লুপ তৈরি করা হয়েছে। i দ্বারা প্রতিবার n এর মান কমানো হয় এবং acc এর সাথে গুণ করা হয়। যখন i এর মান ১ বা তার চেয়ে কম হয়ে যায়, তখন acc রিটার্ন হয়।


রিকার্সন বনাম ইটারেশন: তুলনা

বৈশিষ্ট্যরিকার্সনইটারেশন
কাজের পদ্ধতিফাংশন নিজেই নিজেকে পুনরায় কল করেএকটি নির্দিষ্ট শর্ত পর্যন্ত লুপ চলতে থাকে
স্ট্যাক ব্যবহারপ্রতিটি রিকার্সিভ কল একটি নতুন স্ট্যাক ফ্রেম তৈরি করেলুপ একই স্ট্যাক ফ্রেমে কাজ সম্পন্ন করে
কোড সরলতাছোট এবং সহজ কোডের জন্য উপযুক্তলজিক সহজ হলে সরাসরি ব্যবহার করা যায়
কার্যক্ষমতাবড় ইনপুটে স্ট্যাক ওভারফ্লো হতে পারেবড় ইনপুটে মেমোরি এবং সময় সাশ্রয়ী
ব্যবহার ক্ষেত্রজটিল ও বিভাজ্য সমস্যাগুলিতে কার্যকরসাধারণ পুনরাবৃত্তিমূলক কাজের জন্য উপযুক্ত

কোন পরিস্থিতিতে কোনটি ব্যবহার করবেন?

  • রিকার্সন সাধারণত ব্যবহার করা হয় এমন সমস্যাগুলোর জন্য যেখানে সমাধানটি নিজেই পুনরাবৃত্তির উপর ভিত্তি করে থাকে, যেমন গাছের স্ট্রাকচার বা জটিল বিভাজন। রিকার্সন কোড সহজ এবং সংক্ষিপ্ত করে।
  • ইটারেশন সাধারণত ব্যবহার করা হয় যেখানে নির্দিষ্ট সংখ্যক পুনরাবৃত্তির মাধ্যমে কাজ সম্পন্ন করা সম্ভব। এটি স্ট্যাক ওভারফ্লো প্রতিরোধ করে এবং বড় ইনপুটের জন্য কার্যক্ষম।

সারসংক্ষেপ

রিকার্সন এবং ইটারেশন উভয়ই পুনরাবৃত্তিমূলক কাজের জন্য ব্যবহৃত হয়, তবে প্রয়োগের ক্ষেত্রে এদের মধ্যে পার্থক্য রয়েছে। রিকার্সন জটিল সমস্যার সমাধানে উপযোগী, যখন ইটারেশন বড় ডেটাসেটের জন্য মেমোরি দক্ষতা বৃদ্ধি করে।

common.content_added_by
টপ রেটেড অ্যাপ

স্যাট অ্যাকাডেমী অ্যাপ

আমাদের অল-ইন-ওয়ান মোবাইল অ্যাপের মাধ্যমে সীমাহীন শেখার সুযোগ উপভোগ করুন।

ভিডিও
লাইভ ক্লাস
এক্সাম
ডাউনলোড করুন
Promotion